#include <cmath>
#include <iostream>
#include <vector>
#include <queue>
#include <algorithm>
#include <map>
#include <set>
#include <cstring>
#define endl "\n"
using namespace std;
char ch[110][110];
int fangxiang[8][2]={{0,1},{1,0},{-1,0},{0,-1},{-1,-1},{-1,1},{1,-1},{1,1}};
int k=0,n,m;
void dfs(int x,int y)
{
    ch[x][y]='.';

	for(int i=0;i<8;i++)
	{

		int ax=x+fangxiang[i][0];
		int ay=y+fangxiang[i][1];
		if(ch[ax][ay]=='W'&&ax>=0&&ax<n&&ay<m&&ay>=0)
		{

			dfs(ax,ay);
		  //	ch[ax][ay]='M';
		}
	}
}
int main()
{
	cin>>n>>m;
	for(int i=0;i<n;i++)
	{
		for(int j=0;j<m;j++)
		{
			cin>>ch[i][j];
		}
	}
	for(int i=0;i<n;i++)
	{
		for(int j=0;j<m;j++)
		{
			if(ch[i][j]=='W')
			{

				dfs(i,j);

				k++;
			}
		}
	}
	cout<<k<<endl;
	return 0;
}
